package com.hxrfid.project.domain.vo;

import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import com.hxrfid.common.annotation.ExcelDictFormat;
import com.hxrfid.common.convert.ExcelDictConvert;
import com.hxrfid.common.core.domain.BaseEntity;
import lombok.Data;

import java.math.BigDecimal;
import java.util.Date;
import java.util.List;


/**
 * 订单管理视图对象 bs_order
 *
 * @author hxrfid
 * @date 2025-06-12
 */
@Data
@ExcelIgnoreUnannotated
public class BsOrderVo extends BaseEntity {

    private static final long serialVersionUID = 1L;

    /**
     * 主键
     */
    private Long id;

    /**
     * 订单类型（1商品2卡片3礼品卡）
     */
    private String orderType;

    /**
     * 用户地址id
     */
    private Long userAddressId;

    /**
     * 支付方式
     */
    private String payType;

    /**
     * 支付时间
     */
    @ExcelProperty(value = "订单日期", index = 5)
    private Date payTime;

    /**
     * 订单编号
     */
    @ExcelProperty(value = "订单编号", index = 0)
    private String orderNo;

    /**
     * 下单时间
     */
    private Date orderTime;

    /**
     * 商品名称
     */
    @ExcelProperty(value = "商品名称", index = 1)
    private String productTitles;

    /**
     * 收货人姓名
     */
    @ExcelProperty(value = "收货人姓名", index = 2)
    private String name;

    /**
     * 收货人地址
     */
    @ExcelProperty(value = "收货人地址", index = 3)
    private String address;

    /**
     * 收货人手机号
     */
    @ExcelProperty(value = "收货人电话", index = 4)
    private String phone;

    /**
     * 运费
     */
    private BigDecimal freightPrice;

    /**
     * 订单金额
     */
    private BigDecimal realPrice;

    /**
     * 订单状态（0,购物车，1待付款、2待发货、3待收货、4已收货、5待退款、6已退款、7驳回退款、8已删除、9已取消）
     */
    private String orderStatus;

    /**
     * 会员等级(0普通、1铜牌、2银牌、3金牌)
     */
    private String userLevel;

    /**
     * 评价状态（1待评价2已评价3已追评）
     */
    private String commentStatus;

    /**
     * 下单人id
     */
    private Long userId;

    /**
     * 物流公司
     */
    @ExcelProperty(value = "快递公司", converter = ExcelDictConvert.class, index = 6)
    @ExcelDictFormat(dictType = "logistics_firm")
    private String logisticsFirm;

    /**
     * 物流编号
     */
    @ExcelProperty(value = "快递编号", index = 7)
    private String logisticsNo;

    /**
     * 退款金额
     */
    private BigDecimal backPrice;

    /**
     * 退货物流公司
     */
    private String backLogisticsFirm;

    /**
     * 退货物流编号
     */
    private String backLogisticsNo;

    /**
     * 微信支付单号
     */
    private String transactionId;

    /**
     * 买家备注
     */
    private String remark;

    /**
     * 订单商品
     */
    private List<BsOrderProductVo> details;

    /**
     * 收货地址
     */
    private BsUserAddressVo userAddress;

}
